{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "eb0ecd77",
   "metadata": {},
   "source": [
    "# 1. 音频录制\n",
    "\n",
    "* 安装下载如下3个模块：pip install 模块名称\n",
    "> 1. SpeechRecognition\n",
    "> 2. Pyaudio\n",
    "> 3. pydub"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ea79f886",
   "metadata": {},
   "outputs": [],
   "source": [
    "import speech_recognition\n",
    "r = speech_recognition.Recognizer()\n",
    "with speech_recognition.Microphone() as source:\n",
    "    audio = r.listen(source)\n",
    "# 将数据保存到wav文件中\n",
    "with open(\"1.wav\", \"wb\") as f: \n",
    "    f.write(audio.get_wav_data(convert_rate=16000))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d46fe1b5",
   "metadata": {},
   "source": [
    "# 2. 语音识别 \n",
    "> 1. 百度API：百度的AI账户--（Key，secret） \n",
    "> 2. I/O: input:音频文件（pcm/wav/amr）\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "554e0ead",
   "metadata": {},
   "outputs": [],
   "source": [
    "import bdasr"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "757e521a",
   "metadata": {},
   "outputs": [],
   "source": [
    "bdasr_result  = eval(bdasr.asr('1.wav'))['result'][0]\n",
    "bdasr_result"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ed71a434",
   "metadata": {},
   "source": [
    "# 3. 连接自动回复字典（openai-chatgpt）"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "13545f7f",
   "metadata": {},
   "outputs": [],
   "source": [
    "qa = {\n",
    "    \"你是谁？\":\"我是集美貌和智慧于一体的智能小网同学\",\n",
    "    '你好。':\"你也好，今天听起来心情不错哦\",\n",
    "    '北京科技馆。':\"中国科学技术馆，位于北京市朝阳区北辰东路5号，东临亚运居住区，西濒奥运水系，南依奥运主体育场，北望森林公园，于1958年筹建，建设分为两期工程和新馆工程，分别于1988年9月22日、2000年4月29日、2009年9月16日开放。\"\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8056af77",
   "metadata": {},
   "outputs": [],
   "source": [
    "qa_result = qa.get(bdasr_result)\n",
    "qa_result"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "72120654",
   "metadata": {},
   "source": [
    "# 4. 语音合成\n",
    "\n",
    "> 1. 百度API：百度的AI账户--（Key，secret） \n",
    "> 2. I/O: input:文本\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5bf01f3d",
   "metadata": {},
   "outputs": [],
   "source": [
    "import bdtts\n",
    "bdtts.tts(qa_result)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d25e85ef",
   "metadata": {},
   "source": [
    "# 5. 播放音频"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f66c67fa",
   "metadata": {},
   "outputs": [],
   "source": [
    "from pydub import AudioSegment\n",
    "from pydub.playback import play\n",
    "song = AudioSegment.from_wav('result.wav')\n",
    "play(song)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c83dd3a2",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
